/*
*  Copyright 2019-2020 Zheng Jie
*
*  Licensed under the Apache License, Version 2.0 (the "License");
*  you may not use this file except in compliance with the License.
*  You may obtain a copy of the License at
*
*  http://www.apache.org/licenses/LICENSE-2.0
*
*  Unless required by applicable law or agreed to in writing, software
*  distributed under the License is distributed on an "AS IS" BASIS,
*  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
*  See the License for the specific language governing permissions and
*  limitations under the License.
*/
package me.zhengjie.modules.biz.repository;

import me.zhengjie.modules.biz.domain.Project;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Query;

import java.util.List;

/**
* @website https://eladmin.vip
* @author Admin
* @date 2023-03-23
**/
public interface ProjectRepository extends JpaRepository<Project, Integer>, JpaSpecificationExecutor<Project> {
    @Query(value = "SELECT p.id, p.name, p.desc, p.creator_id, p.created_at, p.updated_at from hj_project_user pu,hj_project p  \n" +
            "WHERE pu.project_id = p.id and pu.user_id = ?1",nativeQuery = true)
    List<Project> findProjectsByUserId(int userId);

    @Query(value = "SELECT p.* FROM hj_project p, hj_project_hazardous_chemicals phc where phc.hct_id = ?1 and phc.project_id = p.id",nativeQuery = true)
    List<Project> findByNameAndType(Integer id, int type);

    @Query(value = "SELECT id FROM hj_project where name= ?1 and `desc`=?2 ",nativeQuery = true)
    Integer findId(String name, String desc);

}
